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REAL PARTY IN INTEREST 

The application is assigned to International Business 
Machines, A Corporation of New York, Armonk, N.Y. 10504. 

RELATED APPEALS AND INTERFERENCES 

There are no related appeals and interferences of the 
claimed invention. 

STATUS OF CLAIMS 

The claims on appeal are Claims 1-30. No claims have been 
canceled. Each of Claims 1-30 has been finally rejected. Each 

of Claims 1-30 is appealed. 

STATUS OF AMENDMENTS 

No amendment has been filed subsequent to the final 
rejection. However, a period has been added to the end of Claim 

15, as suggested by the Examiner. 

SUMMARY OF THE INVENTION 

As described on pages 1-28 of the Application, and as shown 
in Figures 1-19, the present invention provides for managing 
annotated messages, such as error messages generated during 
software code development in a graphical user interface. During 
application code development, once code is created, it must be 
compiled to determine if the code contains errors. If there are 
errors, the compiler will generate error messages to help the 
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code developer diagnose the coding errors. Figure 1 illustrates 

the normal work flow for an application code developer. The code 
is written 40 and compiled 41. The compiler generates error 
messages 42 which are used by the code developer to evaluate and 
fix the errors/bugs 43. This is followed by a recompile 41 which 
is a new pass through the error identification 42 and correction 
steps 43 until the code is error free. Applicants' invention adds 
a new step to the process by providing user annotations to the 
compiler error messages 44. Programmers working with the same 
compilers over extended periods of time, frequently come to 
recognize certain error messages, and know what the likely cause 
and solution to the problems which caused the error messages. 
This information remains in the developer's mind unavailable for 
assisting other developers who encounter the same error messages. 
In addition, programmers recognize a smaller subset of error 
messages, and have their interpretations that are specific to the 
quirks of a particular project. Applicants' invention provides a 
means to allow other code developers to take advantage of this 
knowledge by allowing user annotations to compiler error 
messages. A second, initially empty, error message file is 
created and maintained for each error messages generated by the 
compiler. When a code developer adds a note to the compiler 
error message, the user's note is stored in the second error 
message file. Turning to Figure 2, compiler error messages 53 
are textual material stored in a message catalog 50. The 
compiler error messages are identified and accessed by way of 
message keys 52 for display to a code developer in a window on a 
user's workstation. Message catalog name 51 is combined with 
message keys 52 to generate unique annotation dialog keys 54 
which are used to access the annotations 56 for each compiler 
error message stored in the separate file. Applicants' invention 
allows this separate annotation file to be transmitted or copied 
to another code developer's workstation and when the compiler 
generates the error message, the appropriate annotation will be 
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displayed thus allowing multiple code developers to share 

experiences . 

ISSUES PRESENTED FOR REVIEW 

1. Whether the Examiner's rejection of Claims 1-30 under 35 
U.S.C. Section 103(a) as being unpatentable over Hughes (U.S. 
Pat. 6,275,223) in view of Mueller (U.S. Pat. 5,673,390), is 
proper. 

GROUPING OF CLAIMS 

With respect to the Examiner's rejection of Claims 1-30 
under 35 U.S.C. Section 103(a), the claims are grouped as 
follows : 

1. Claims 1-12, 16-17 and 18-27 stand together; 

2. Claims 13-15 and 29-30 stand together; 

3. Claim 28 stands alone. 



ARGUMENT 
35 U.S.C. Section 103(a) 

Claims 1-30 stand rejected under 35 U.S.C. Section 103(a) as 
being unpatentable over Hughes in view of Mueller. That 
rejection is not well founded and should be reversed. 

The Examiner's rejection of the claims is erroneous for 
several reasons. The combination suggested by the Examiner is 
not fairly suggested by the references. Moreover, the 
references cannot be combined to achieve Applicants' invention. 

The Hughes reference discloses a code inspection tool for 
allowing developers to compile annotation data and forward the 
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annotation data from a graphical user interface to a centralized 

data store (See Hughes, Col. 3, Lines 57-60). Hughes discloses 
during code inspection sessions, that all developers view a 
display, which sets out original source code, side by side with 
new source code on a line by line basis (See Hughes, Col. 3, 
Lines 62-67), matching the line numbers of the original source 
with those of the new source code. Annotations to the source 
code lines are indicated by further icons next to the appropriate 
lines (See Hughes, Col. 4, Lines 3-5). Hughes fails to show 
annotations for errors generated from compiled source 
code, storage* of those annotations in a separate file, or the use 
of a unique key to store the annotations in the separate file as 
shown in Applicants' invention. 

Mueller discloses a technique for interactively displaying 
error messages, such as parser or compiler messages, associated 
with a user's source code. Mueller discloses that compilers 
typically provide programmers with a compiler listing which lists 
the source code along with the errors (See Mueller, Col. 1, Lines 
29-31) . Mueller teaches that these errors maybe listed at the 
end of the source listing, interspersed through the source 
listing, or in some instances the errors are displayed in the 
same window in which the source file is ..being edited (See 
Mueller, Col. 1, Lines 31-36). Mueller specifically address 
special problems where compiler errors code emanate from multiple 
sources, such as a local parser or compiler, as well as a remote 
compiler which runs on a second computer, such as a mainframe 
host computer connected through a communication link (See 
Mueller, Col. 1, Lines 52-59) . 

The subject matter of Claim 1, taken as a whole, is neither 
taught nor suggested by any combination of the references relied 
upon by the Examiner. Specifically, neither of the reference 
teaches or suggests displaying a compiler error message having a 
separate empty error file into which an annotation is associated 
and stored. Hughes is directed to source code inspection which 
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is far different from compiler error examination. The reasons 

why such a feature cannot be implemented in Hughes is the fact 
that it would require an empty error file for each line of source 
code, which would require enormous storage requirements. 
Applicants' invention in contrast is working only with the errors 
generated from compiler error diagnosis which results in limiting 
annotations and storage to a limited set of errors. Mueller also 
fails to disclose this feature of Applicants' invention. Mueller 
is directed to the gathering of error messages from multiple 
locations and displaying those errors in response to a user's 
request. There is no teaching in either reference that would 
cause one skilled in the art to make Applicants' claimed 
invention. Similarly, neither of the references discloses 
associating an annotation with a compiler error message using a 
unique key as disclosed in Applicants' invention. Applicants' 
invention disclose that compiler error messages are identified 
and accessed by way of message keys 52 (Figure 2) for display to 
a code developer in a window on a user's workstation. Message 
catalog name 51 (Figure 2) is combined with message keys 52 to 
generate unique annotation dialog keys 54 which are used to 
access the annotations 56 for each compiler error message stored 
in a separate file. There is no teaching in either of the 
references that would suggest the .generation of a unique 
annotation dialog key as in Applicants' invention. Accordingly, 
the Examiner's rejection of Claim 1 is erroneous and should be 
reversed. Claims 2-12, 16-17 and 18-27 stand or fall with Claim 
1. 

With respect to Claim 13, neither of the references teaches 
an event driven control component for displaying using a unique 
key an associated annotation in said user display. In Hughes, the 
source code line numbers are used to associate an annotation with 
a particular line of source code. Mueller requires that the 
error message itself, and not an annotation, be stored such that 
the type and location maybe determined. Neither of the 
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references disclose the use of a unique key for displaying an 
associated annotation to a user. Accordingly, the Examiner's 
rejection of Claim 13 is erroneous and should be reversed. 
Claims 14-15 and 29-30 stand or fall with Claim 13. 

With respect to Claim 28, there is no teaching or suggestion 
in any of the references of the concept of selectively displaying 
an annotation with a compiler error message and causing a 
computer to effect presenting an edit panel in said graphic user 
interface for user entry of new or modified annotations. 
Accordingly, the Examiner's rejection of Claim 28 is erroneous 
and should be reversed. Claim 28 stands alone. 



It is therefore respectfully requested that the Examiner's 
rejection of Claims 1-30 under 35 U.S.C. Section 103(a), is 
erroneous. Accordingly, it is respectfully urged that the 
Examiner's rejection be reversed in all respects. 

Please charge the $ 330.00 fee for submission of a brief in 
support of appeal to Deposit Account No. 09-0447. No additional 
fee is seen to be required. Please charge any excess or credit 
any overpayment to our Deposit Account No. 09-0447. 

Respectfully submitted. 



CONCLUSION 




David A. Mims, Jr. -Attorney 
Registration No. 32,708 
(512) 823-0950 
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APPENDIX 



1 . A method for managing compiler error messages, comprising the steps of: 

displaying a compiler error message having a separate empty error file to a user; 
accepting from said user an annotation to said compiler error message; 
associating said annotation with said compiler error message using a unique key and 
storing said annotation in said separate empty error file; and 
thereafter selectively displaying said annotation with said compiler error message. 

2. The method of claim 1, said selectively displaying step further comprising the steps of: 

displaying with said compiler error message indicia representing the existence of 
said annotation; 

selectively receiving from said user a request to display said annotation; and 
displaying said annotation with said compiler error message. 

3. The method of claim 1, said accepting step further comprising the steps of: 

selectively presenting to said user an edit panel; and 

receiving from said user said annotation input associated with said compiler error 
message to said edit panel. 

4. The method of claim 1, further comprising the steps of: 
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selecting a compiler error message having a first key from a first file of compiler 

error messages for display to said user; and 

associating in a second file said annotation to said selected compiler error message 
in said first file. 

5. The method of claim 4, further comprising the steps of: 

providing compiler error message identifying indicia for each compiler error message 
in said first file; 

generating annotation identifying indicia as a function of said compiler error message 
identifying indicia. 



6. The method of claim 4, further comprising the steps of: 

upon presenting a compiler error message from said first file, determining the 
presence of a corresponding annotation in said second file using said second key; 

responsive to the presence of said corresponding annotation, 
displaying with said compiler error message indicia representing the existence of said 
annotation; 

selectively receiving from said user a request to display said 
annotation; and 

responsive to receiving the request from said user, displaying said 

annotation with said compiler error message using said second key. 
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7. The method of claim 1, further comprising the steps of: 

during processing of application code entered by a user, identifying a compiler error 
in said code; 

selecting and presenting to said user a compiler error message; 
identifying and presenting to said user an annotation corresponding to said compiler 
error message; and 

enabling and selectively receiving said annotation and a modified annotation 
from said user for association with said compiler error message. 

8. The method of claim 7, further comprising the steps of: 

preserving a history of compiler error messages presented to said user; 
enabling user selection one of said compiler error message from said history of 
compiler error messages; and 

selectively receiving from said user an annotation to the compiler error message 
selected from said history. 

9. The method of claim 1, further comprising the step of presenting said annotation to other 
users receiving said compiler error message. 

10. The method of claim 4, further comprising the step of enabling access by other users to 
said second file containing said annotations associated with said compiler error messages. 
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11. A method for managing compiler error messages in a graphic user interface, comprising 
the steps of: 

selecting and displaying a compiler error message having a separate empty error file 
to a user; 

accepting from said user an annotation to said compiler message; 

associating said annotation with said compiler error message and storing said 
annotation in said separate empty error file using a unique key; 
thereafter selectively displaying said annotation with said compiler error message; and 

presenting an edit panel in said graphic user interface for user entry of new or 
modified annotations. 

12. A system for managing compiler error messages at a user interface, comprising: 

means for displaying a compiler error message having a separate empty error file to a 
user; 

means for accepting from said user an annotation to said compiler error message; 
means for associating said annotation with said compiler error message and storing 
said annotation in said separate empty error file using a unique key; and 

means for selectively displaying said annotation with said compiler error message. 

13. A system for presenting compiler error messages in a user display, comprising: 
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a first file for storing a plurality of compiler error messages, each said compiler error 

message identified by a message key; 

a second file for storing a plurality of annotations, each said annotation associated 
with a corresponding one of said compiler error message; 

a first event driven control component for selecting from said first file and displaying 
a compiler error message from said first file in said user display; 

a second event driven control component for determining the presence in said second 
file of an annotation associated with said displayed compiler error message; and 

a third event driven control component for displaying using a unique key said 
associated annotation in said user display. 

14. The system of claim 13, further comprising a fourth control component responsive to 
entry in said user display of a annotation to a displayed compiler error message, for 
adding said annotation to said second file using a unique key associated with said 
displayed compiler error message. 

15. (Amended) The system of claim 14, further comprising an editor for receiving via an 

annotation panel in said user display said annotation. 

16. A program storage device readable by a machine, tangibly 

embodying a program of instructions executable by a machine to perform 

the method steps for managing compiler error messages of claim 1. 
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A computer program product or computer program element for managing a compiler 
error message display according to claim 1. 

An article of manufacture comprising: 

a computer useable medium having computer readable program code means 
embodied therein for managing compiler error messages, the computer readable program 
means in said article of manufacture comprising: 

computer readable program code means for causing a computer to effect displaying a 
compiler error message to a user having a separate empty error file; 

computer readable program code means for causing a computer to effect accepting 
from said user an annotation to said compiler error message; 

computer readable program code means for causing a computer to effect associating 
said annotation with said compiler error message and storing said annotation in said 
separate empty error file using a unique key; and 

computer readable program code means for causing a computer to effect thereafter 
selectively displaying said annotation with said compiler error message. 

The article of manufacture of claim 18, said computer readable program code means for 

causing a computer to effect selectively displaying further comprising: 

computer readable program code means for causing a computer to effect displaying 

with said compiler error message indicia representing the existence of said annotation; 
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computer readable program code means for causing a computer to effect selectively 

receiving from said user a request to display said annotation using a unique key; and 

computer readable program code means for causing a computer to effect displaying said 
annotation with said compiler error message. 

The article of manufacture of claim 18 5 said computer readable program code 
means for causing a computer to effect accepting further comprising: 

computer readable program code means for causing a computer to 
effect selectively presenting to said user an edit panel; and 

computer readable program code means for causing a computer to 
effect receiving from said user said annotation input to said edit panel associated with one 
of said compiler error messages. 

The article of manufacture of claim 18, further comprising: 

computer readable program code means for causing a computer to 

effect selecting a compiler error message from a first file of compiler error messages for 

display to said user; and 

computer readable program code means for causing a computer to 

effect associating in a second file said annotation to a corresponding compiler error 

message in said first file. 
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22. The article of manufacture of claim 21 , further comprising: 

computer readable program code means for causing a computer to effect providing 
compiler error message identifying indicia for each compiler error message in said first 
file; 

computer readable program code means for causing a computer to effect generating 
annotation identifying indicia as a function of said compiler error message identifying 
indicia. 

23 . The article of manufacture of claim 2 1 , further comprising: 

computer readable program code means for causing a computer to effect, upon 
presenting a compiler error message from said first file, determining the presence of a 
corresponding annotation in said second file; 

computer readable program code means for causing a computer to effect, responsive 
to the presence of said corresponding annotation, displaying with said compiler error 
message indicia representing the existence of said annotation; 

computer readable program code means for causing a computer to effect selectively 
receiving from said user a request to display said annotation; and 

computer readable program code means for causing a computer to effect responsive to 
receiving the request from said user, displaying said annotation with said compiler error 
message. 

24. The article of manufacture of claim 18, further comprising: 
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computer readable program code means for causing a computer to effect, during 

processing of application code by a compiler entered by a user, identifying a compiler 
error in said code; 

computer readable program code means for causing a computer to effect, selecting and 
presenting to said user an error message corresponding to said error; 

computer readable program code means for causing a computer to effect identifying and 
presenting to said user an annotation corresponding to said compiler error message; and 

computer readable program code means for causing a computer to effect enabling and 
selectively receiving said annotation and a modified annotation from said user for 
association with said compiler error message. 

25. The article of manufacture of claim 24, further comprising: 

computer readable program code means for causing a computer to effect 
preserving a history of compiler error messages presented to said user; 

computer readable program code means for causing a computer to effect enabling 
user selection of one of said compiler error message from said history of compiler 
error messages; and 

computer readable program code means for causing a computer to effect selectively 
receiving from said user an annotation to the compiler error message selected from said 
history. 
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26. The article of manufacture of claim 18, further comprising computer readable program 

code means for causing a computer to effect presenting said annotation to other users 
receiving said compiler error message. 

27. The article of manufacture of claim 21 5 further comprising computer readable 
program code means for causing a computer to effect enabling access by other users 
to said second file containing said annotation associated with said compiler error file. 

28. An article of manufacture comprising: 

a computer useable medium having computer readable program code means 
embodied therein for managing compiler error messages in a graphic user interface, the 
computer readable program means in said article of manufacture comprising: 

computer readable program code means for causing a computer to effect selecting 
and displaying a compiler error message having a separate empty error file to a user; 

computer readable program code means for causing a computer to effect accepting 
from said user an annotation to said compiler error message; 

computer readable program code means for causing a computer to effect 
associating said annotation with said compiler error message and storing said annotation 
in said separate empty error file using a unique key; 

computer readable program code means for causing a computer to effect thereafter 
selectively displaying said annotation with said compiler error message; and 
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computer readable program code means for causing a computer to effect 

presenting an edit panel in said graphic user interface for user entry of new or modified 
annotations. 

29. A computer program product for presenting compiler error messages in a user display, 
comprising: 

a first file for storing a plurality of compiler error messages, each said compiler 
error message identified by a message key; 

a second file for storing a plurality of annotations, each said annotation associated with 
a corresponding one of said compiler error message; 

a first event driven control component for selecting from said first file a 
compiler error message for presentation in said user display; 

a second event driven control component for determining the presence in said 
second file of an annotation associated with said compiler error message; and , 

a third event driven control component for displaying said associated annotation in 
said user display. 

30. The computer program product of claim 29, further comprising a fourth control 
component responsive to entry in said user display of a annotation to a displayed compiler 

error message, for adding said annotation to said second file associated with said displayed 
compiler error message 
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presenting an edit panel in said graphic user interface for user entry of new or modified 

annotations. 
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